package com.hison.util;

import com.google.common.base.Predicates;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

/**
 * @ClassName: Swagger2
 * @Descripiton: Swagger2 配置类
 * @Author: 小郑
 * @Date： 2024/1/12 13:59
 * @Version：1.8
 **/
//@Configuration
//@EnableSwagger2
public class Swagger2 {
    @Bean
    public Docket createRestApi(){
        //指定Api类型为Swagger2
        return new Docket(DocumentationType.SWAGGER_2)
                //指定文档汇总信息
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors
                        //指定controller包路径
                        .basePackage("com.hison.controller"))

                // 对所有api进行监控
//                .apis(RequestHandlerSelectors.any())

                //不显示错误的接口地址，也就是错误路径不监控
                .paths(Predicates.not(PathSelectors.regex("/error.*")))
                //指定展示所有controller
                .paths(PathSelectors.any())
                .build();
    }

    private ApiInfo apiInfo() {
        //返回一个apiinfo
        return new ApiInfoBuilder()
                //文档页标题
                .title("个人博客系统在线接口文档")
                .contact(
                        // 联系人信息
                        new Contact(
                                "hison",
                                "",
                                "zhenghaosheng06@163.com")
                )
                // 详细信息
                .description("个人博客网站")
                // 文档版本号
                .version("1.0.1")
                //网站地址
                .termsOfServiceUrl("https://hison.love")
                .build();
    }
}